Security News
Supply Chain Attack Detected in Solana's web3.js Library
A supply chain attack has been detected in versions 1.95.6 and 1.95.7 of the popular @solana/web3.js library.
react-chartjs-2
Advanced tools
The react-chartjs-2 npm package is a React wrapper for Chart.js, a popular JavaScript library for creating simple yet flexible charts. It allows developers to create various types of charts such as line, bar, radar, doughnut, and pie charts, among others, with ease. The package provides React components that encapsulate Chart.js functionality, making it easy to integrate into React applications.
Line Chart
This code sample demonstrates how to create a simple line chart using react-chartjs-2. It includes a dataset for monthly sales and configures the chart to start the y-axis at zero.
{"import { Line } from 'react-chartjs-2';\n\nconst data = {\n labels: ['January', 'February', 'March', 'April', 'May', 'June'],\n datasets: [{\n label: 'Monthly Sales',\n data: [65, 59, 80, 81, 56, 55],\n fill: false,\n borderColor: 'rgb(75, 192, 192)',\n tension: 0.1\n }]\n};\n\nconst options = {\n scales: {\n y: {\n beginAtZero: true\n }\n }\n};\n\nfunction MyLineChart() {\n return <Line data={data} options={options} />;\n}"}
Bar Chart
This code sample shows how to create a bar chart with react-chartjs-2. It sets up a dataset with different colors for each bar representing votes for different options.
{"import { Bar } from 'react-chartjs-2';\n\nconst data = {\n labels: ['Red', 'Blue', 'Yellow', 'Green', 'Purple', 'Orange'],\n datasets: [{\n label: 'Votes',\n data: [12, 19, 3, 5, 2, 3],\n backgroundColor: [\n 'rgba(255, 99, 132, 0.2)',\n 'rgba(54, 162, 235, 0.2)',\n 'rgba(255, 206, 86, 0.2)',\n 'rgba(75, 192, 192, 0.2)',\n 'rgba(153, 102, 255, 0.2)',\n 'rgba(255, 159, 64, 0.2)'\n ],\n borderColor: [\n 'rgba(255, 99, 132, 1)',\n 'rgba(54, 162, 235, 1)',\n 'rgba(255, 206, 86, 1)',\n 'rgba(75, 192, 192, 1)',\n 'rgba(153, 102, 255, 1)',\n 'rgba(255, 159, 64, 1)'\n ],\n borderWidth: 1\n }]\n};\n\nfunction MyBarChart() {\n return <Bar data={data} />;\n}"}
Doughnut Chart
This code sample illustrates how to create a doughnut chart using react-chartjs-2. It includes a dataset with three segments, each with its own color.
{"import { Doughnut } from 'react-chartjs-2';\n\nconst data = {\n labels: ['Red', 'Blue', 'Yellow'],\n datasets: [{\n data: [300, 50, 100],\n backgroundColor: [\n '#FF6384',\n '#36A2EB',\n '#FFCE56'\n ],\n hoverBackgroundColor: [\n '#FF6384',\n '#36A2EB',\n '#FFCE56'\n ]\n }]\n};\n\nfunction MyDoughnutChart() {\n return <Doughnut data={data} />;\n}"}
Recharts is a composable charting library built on React components. It uses D3.js under the hood for sophisticated charting capabilities. Compared to react-chartjs-2, Recharts offers a more React-friendly API with the ability to compose charts using declarative components.
Victory is another React chart library that provides an extensive collection of composable components for building interactive data visualizations. Victory charts are highly customizable and can be styled using standard inline styles, which might appeal to developers looking for a more integrated React experience compared to react-chartjs-2.
Nivo provides a rich set of dataviz components built on top of D3.js, with a strong emphasis on motion and interactivity. It offers a higher level of abstraction compared to react-chartjs-2 and includes a wide range of chart types with beautiful default styles and animations.
React wrapper for Chart.js 2 Open for PRs and contributions!
As of 2.x we have made chart.js a peer dependency for greater flexibility. Please add chart.js as a dependency on your project to use 2.x. Currently, 2.5.x is the recommended version of chart.js to use.
Live demo: reactchartjs.github.io/react-chartjs-2
To build the examples locally, run:
npm install
npm start
Then open localhost:8000
in a browser.
We have to build the package, then you can run storybook.
npm run build
npm run storybook
Then open localhost:6006
in a browser.
npm install --save react-chartjs-2 chart.js
yarn add react-chartjs-2 chart.js
Check example/src/components/* for usage.
import { Doughnut } from 'react-chartjs-2';
<Doughnut data={...} />
In order for Chart.js to obey the custom size you need to set maintainAspectRatio
to false, example:
<Bar
data={data}
width={100}
height={50}
options={{ maintainAspectRatio: false }}
/>
Chart.js instance can be accessed by placing a ref to the element as:
class MyComponent extends React.Component {
constructor(props) {
super(props);
this.chartReference = React.createRef();
}
componentDidMount() {
console.log(this.chartReference); // returns a Chart.js instance reference
}
render() {
return (<Doughnut ref={this.chartReference} data={data} options={options} />)
}
}
Canvas node and hence context, that can be used to create CanvasGradient background, is passed as argument to data if given as function:
This approach is useful when you want to keep your components pure.
render() {
const data = (canvas) => {
const ctx = canvas.getContext("2d")
const gradient = ctx.createLinearGradient(0,0,100,0);
...
return {
...
backgroundColor: gradient
...
}
}
return (<Line data={data} />)
}
Chart.js defaults can be set by importing the defaults
object:
import { defaults } from 'react-chartjs-2';
// Disable animating charts by default.
defaults.global.animation = false;
If you want to bulk set properties, try using the lodash.merge function. This function will do a deep recursive merge preserving previously set values that you don't want to update.
import { defaults } from 'react-chartjs-2';
import merge from 'lodash.merge';
// or
// import { merge } from 'lodash';
merge(defaults, {
global: {
animation: false,
line: {
borderColor: '#F85F73',
},
},
});
You can access the internal Chart.js object to register plugins or extend charts like this:
import { Chart } from 'react-chartjs-2';
componentWillMount() {
Chart.pluginService.register({
afterDraw: function (chart, easing) {
// Plugin code.
}
});
}
If you're using Chart.js 2.6 and below, add the showLines: false
property to your chart options. This was later added in the default config, so users of later versions would not need to do this extra step.
A function to be called when mouse clicked on chart elememts, will return all element at that point as an array. Check
{
onElementsClick: (elems) => {},
getElementsAtEvent: (elems) => {},
// `elems` is an array of chartElements
}
Calling getElementAtEvent(event) on your Chart instance passing an argument of an event, or jQuery event, will return the single element at the event position. If there are multiple items within range, only the first is returned Check
{
getElementAtEvent: (elems) => {},
// => returns the first element at the event point.
}
Looks for the element under the event point, then returns all elements from that dataset. This is used internally for 'dataset' mode highlighting Check
{
getDatasetAtEvent: (dataset) => {}
// `dataset` is an array of chartElements
}
You will find that any event which causes the chart to re-render, such as hover tooltips, etc., will cause the first dataset to be copied over to other datasets, causing your lines and bars to merge together. This is because to track changes in the dataset series, the library needs a key
to be specified - if none is found, it can't tell the difference between the datasets while updating. To get around this issue, you can take these two approaches:
label
property on each dataset. By default, this library uses the label
property as the key to distinguish datasets.datasetKeyProvider
prop to your chart component, which would return a unique string value for each dataset.src
, lib
and the build process)NOTE: The source code for the component is in src
. A transpiled CommonJS version (generated with Babel) is available in lib
for use with node.js, browserify and webpack. A UMD bundle is also built to dist
, which can be included without the need for any build system.
To build, watch and serve the examples (which will also watch the component source), run npm start
. If you just want to watch changes to src
and rebuild lib
, run npm run watch
(this is useful if you are working with npm link
).
MIT Licensed Copyright (c) 2017 Jeremy Ayerst
FAQs
React components for Chart.js
The npm package react-chartjs-2 receives a total of 1,063,145 weekly downloads. As such, react-chartjs-2 popularity was classified as popular.
We found that react-chartjs-2 demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
A supply chain attack has been detected in versions 1.95.6 and 1.95.7 of the popular @solana/web3.js library.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.